python - 部署到 Elastic Beanstalk 时运行 Django 迁移
全部标签 我有一个现有的数据库,我正在将以前的“NULL”列转换为具有默认值的列(并使用所述默认值填充该列)。但是,该值是我需要创建的记录的ID。如果我将此记录放入db/seeds.rb,它不会运行,因为db/seeds.rb在迁移之后运行——但迁移需要种子数据。如果我在迁移中保留记录创建,那么如果我使用db:load创建新数据库,我将不会获得记录。除了在db/seeds.rb和迁移中复制它之外,还有更好的方法吗?谢谢! 最佳答案 虽然我能理解您希望保持DRY并且不必在migration和seeds.rb中都写这个,但我认为您应该在两个地方都
我最终成功复制了9个迁移。(我认为这是因为我在我的开发和生产机器上安装/更新了Gems和/或引入了它们的迁移,但在这个阶段我不完全确定。)我从生产服务器上的rails目录中移出一组重复的9,但现在我想在生产中db:migrate以运行另一次迁移,我得到:$bundleexecrakedb:migrateRAILS_ENV=production[DEPRECATIONWARNING]NestedI18nnamespacelookupunder"activerecord.attributes.checkout"isnolongersupported==CreatePages:migrati
我是Rails的新手,开始了一个我对我的模型和数据库模式不满意的项目。我想从头开始,但保留我所有的观点,Controller。执行此操作的最佳方法是什么?我想删除所有迁移和所有模型。在此过程之后不应留下不相关的文件(例如不再使用的迁移)。如果有帮助,我正在使用Rails3.1谢谢! 最佳答案 首先,将您的迁移回滚到版本0。rakedb:migrateVERSION=0然后您手动删除您的迁移和模型,保持Controller和View完好无损。 关于ruby-on-rails-回滚所有rai
我打算在大学学习Ruby、Haskell和Prolog。现在,我想知道什么应该引起我的大部分注意。我有半年的时间来完成这三门类(class),这意味着我需要选择一种语言来获得我的课外时间。其他我将学习的内容足以在类(class)中做得很好。我对Haskell和Prolog非常熟悉,知道学习它们会教会我一些非常重要的计算机科学概念。我不太确定ruby。通过一些教程和介绍,我觉得ruby是很多肤浅的魔法。现在我问ruby的人:如果我决定不再使用它,我会得到什么,在我花了半年时间学习它之后,Python还没有教我。虽然我意识到这是一个很有争议的潜在话题,但这个问题并不是为了“证明”r
我最近更新了我的capistranogem到版本3.1.0,从那时起capproductiondeploy顺利通过,但目标deploy:restart没有被调用。我的服务器部署在AmazonEC2上的Ubuntu12.10上。为什么会这样? 最佳答案 Capistrano3默认不再运行该任务,因为许多应用服务器不需要它。将此添加到您的config/deploy.rb:after'deploy:publishing','deploy:restart'来自releasenotes:Breakingchanges:deploy:resta
尝试将Rails5应用程序部署到heroku时,出现以下错误,当它到达Running:rakeassets:precompile时:remote:ExecJS::ProgramError:SyntaxError:Unexpectedtoken:name(autoRegisterNamespace)(line:14767,col:7,pos:457487)remote:Errorremote:atnewJS_Parse_Error(:3623:11948)remote:atjs_error(:3623:12167)remote:atcroak(:3623:21858)remote:att
我们正在使用EngineYardCloud部署我们的RubyonRails应用程序。我们正在运行Railsv2.3.3。EngineYardCloud以类似于Capistrano的方式部署到AWS实例。每次部署后,我们都会遇到InvalidAuthenticityToken错误。具体来说,任何以前访问过我们的应用程序然后在部署后访问并尝试提交表单的用户都会收到无效的真实性token错误。此错误一直存在,直到他们为网站重置cookie。在他们重置cookie后,该网站按预期运行,没有错误。我们正在使用ActiveRecord的session存储并将session保存到数据库中。这是我们看
我和一位同事在共享某些模型的不同项目中工作。因此,我们通过git子模块共享模型。此外,我们还希望能够共享迁移:这样,我同事的迁移将在我项目的文件夹db/migrate/other_db中。如何配置Rails迁移以在这个额外的文件夹中运行迁移? 最佳答案 在您的配置文件中(config/application.rb用于所有环境或config/environments/$(environment).rb仅用于特定环境)添加此行:config.paths['db/migrate']+='db/migrate/other_db'如果你想改变
我有一个运行旧版本Spree(开源购物车)的Rails3应用程序。我正在将它更新到最新版本。这需要我在数据库上运行大量迁移以与最新版本兼容。但是,应用程序当前的数据库大约为300mb,要在我的本地计算机(macosx10.7、4gbram、2.4GHzCore2Duo)上运行迁移需要三天以上的时间才能完成。我能够使用AmazonEC2实例(高I/O按需实例,四倍超大)将这个时间减少到仅16小时。但是16小时仍然太长,因为我必须关闭网站才能执行此更新。有没有人有任何其他建议来降低这个时间?或提高迁移性能的任何提示?仅供引用:在Amazon实例上使用Ruby1.9.2和Ubuntu。
我想知道是否有人有任何插件或capistrano配方可以通过在部署时或在本地部署之前构建所有页面缓存的html来“预热”rails应用程序的页面缓存。我有一些主要是静态的网站,它们变化不大,如果已经编写了html,运行速度会更快,而不是要求一位访问者访问该网站。与其自己创建它(看起来很简单,但它的优先级很低),它是否已经存在? 最佳答案 您可以使用wget或其他程序来抓取站点。事实上,这种场景在其手册页中被提及为一种用途:ThisoptiontellsWgettodeleteeverysinglefileitdownloads,af